www.mecatronicadegaragem.blogspot.com



# Aula 17 Periférico de Comunicação

#### Microcontroladores PIC18 – Programação em C



Prof. Ítalo Jáder Loiola Batista

Universidade de Fortaleza - UNIFOR Centro de Ciências Tecnológicas - CCT

E-mail: <u>italoloiola@unifor.br</u>

Jan/2011

## Introdução

- Em várias aplicações utilizando uC pode ser necessário a comunicação entre o UC e um ou mais dispositivos externos;
- □ As técnicas de comunicação podem ser divididas em duas categorias: paralela e serial;

### Comunicação Serial X Paralela

- □ Serial:
  - □ Transmissão de dados mais simples;
  - Utiliza apenas um canal de comunicação;
  - Menor velocidade de transmissão;
- □ Paralela:
  - □ Transmissão de dados mais custosa e complexa;
  - □ Requer mais de um canal de comunicação;
  - Maior velocidade de transmissão;

# Comunicação Serial X Paralela

| Característica    | Serial   | Paralelo |
|-------------------|----------|----------|
| Velocidade        | Ψ        | <b>^</b> |
| Custo             | •        | <b>^</b> |
| Imunidade a ruído | <b>↑</b> | •        |
| Distância         | <b>↑</b> | <b>→</b> |

#### Transmissão Serial

□ A Comunicação Serial pode ser classificada em duas categorias:

#### **ASSÍNCRONO**



#### SÍNCRONO



#### Transmissão Serial

- Periférico que converte dados em paralelo para dados seriais.
  - □ Transforma bytes de informações em bits individuais passíveis de serem transmitidos.
- A operação inversa também é realizada:
  - Os bits recebidos são convertidos para bytes novamente.

#### Transmissão Serial

- □Tipos de transferência:
  - □ **Simplex**: A informação é transmitida em um único sentido, ou seja, somente do transmissor para o receptor.
  - □ Half-Duplex: A informação é transmitida em ambos os sentidos, embora de forma alternada.
  - □ **Full-Duplex**: A informação é transmitida em ambos os sentidos de forma simultânea.
- □ Tipo de comunicação:
  - ■Broadcast;
  - ■Master/slave;
  - ■Ponto a ponto;

#### Sinais no tempo

- Bit de start;
- Palavra de dados;
- Bit de paridade: par ou ímpar;
- Bit de stop;



#### Interface Serial: UART

- UART
  - Universal Asynchronous Receiver Transmiter;
- È um protocolo de comunicação serial assíncrono desenvolvido em 1960 para permitir acomunicação ponto a ponto entre computadores e terminar remotos;
- A UART tornou-se tão popular que é amplamente utilizada até hoje em muitas aplicações;

#### Interface Serial: EUSART

- Praticamente todos os microcontroladores da série PIC18 vêm integrados com pelo menos um módulo de transmissão e recepção de dados serial;
- O PIC18F4520 possui um mpodulo de cmunicação serial chamado EUSART (Enhanced Universal Syncrhnous Receiver Transmiter);
- A principal evolução da EUSART é a capacidade de detectar automaticamente a taxa de transferência, um recurso chamado auto-baud detect;

## Elementos de Configuração

- Taxa de transmissão (limitada a ~ 20Kb/s tx. de dados):
  - □ A velocidade de transmissão deve ser escolhida considerando-se a velocidade de recepção (medida em bauds).

#### Número de bits de dados:

☐ Sete bits se os dados a serem enviados estiverem no formato texto e oito se estiverem no formato binário.

#### Paridade:

□ Indica quando não há uma correspondência exata entre a informação transmitida e recebida.

#### ■ Start Bit e Stop Bit:

□ Permite identificar o início e o fim da transmissão de um dado.

#### Padrão RS232

- □ Padrão de comunicação serial criado pela EIA (Electronics Industry Association)
  - RS: Recommended Standard
- □ Padrão elétrico e mecânico;
- Criado para conectar computador (DTE) em modem (DCE – Data Communication Equipment);
- □ Sinais de handshake (RTS, CTS, DTR, RI, ...);

#### Padrão RS232

- O padrão RS232 especifica:
  - Tensões
  - Temporização
  - Funções dos sinais
  - Um protocolo de comunicação;
  - Conectores mecânicos;
- Conhecido também como EIA232;

## Taxa de Transferência (Baud Rate)

- A taxa de transferência refere-se à velocidade com que os dados são enviados através de um canal;
- É medido em transições elétricas por segundo.
- Uma taxa de 9600 bauds corresponde a uma transferência de 9600 dados por segundo, ou um período de aproximadamente, 104 ms (1/9600 s).



## Taxa de Transferência (Baud Rate)

Seleção da fórmula para cálculo do baud rate;

| Configuration Bits |       | its  | BRG/EUSART Mode     | David Data Farmania |  |
|--------------------|-------|------|---------------------|---------------------|--|
| SYNC               | BRG16 | BRGH | BRG/EUSART Mode     | Baud Rate Formula   |  |
| 0                  | 0     | 0    | 8-Bit/Asynchronous  | Fosc/[64 (n + 1)]   |  |
| 0                  | 0     | 1    | 8-Bit/Asynchronous  | Fosc/[16 (p + 1)]   |  |
| 0                  | 1     | 0    | 16-Bit/Asynchronous | Fosc/[16 (n + 1)]   |  |
| 0                  | 1     | 1    | 16-Bit/Asynchronous |                     |  |
| 1                  | 0     | x    | 8-Bit/Synchronous   | Fosc/[4 (n + 1)]    |  |
| 1                  | 1     | х    | 16-Bit/Synchronous  |                     |  |

**Legend:** x = Don't care, n = value of SPBRGH:SPBRG register pair

## Taxa de Transferência (Baud Rate)

#### Exemplo:

- Qual valor deve ser escrito no par de registradores SPBRGH:SPBRG para uma transmissão assíncrona, baud rate de 19200bps e uma Fosc de 8MHz?
- Deduzindo SPBRG na fórmula para 8 bits, temos:
- SPBRGH = Fosc / (M x baud rate) 1
- Se BRGH = M = 64
  - □ SPBRGH = 5,51 aprox. = 6, logo Baud Rate = 17857,14
- Se BRGH = M = 16
  - □ SPBRGH = 25,04 aprox. = 25, logo Baud Rate = 19230,76

#### Tensões dos sinais

- □ "1" lógico: Tensões de -3V a -25V em relação ao pino de terra;
- □ "0" lógico Tensões de +3V a +25V em relação ao pino de terra;
- □ Para o intervalo de tensões entre -3V e +3V não é associado um estado do sinal, sendo uma região de transição;



#### Pinos do conector DB9



| Pin | Name | Dir      | Description         |
|-----|------|----------|---------------------|
| 1   | CD   | +        | Carrier Detect      |
| 2   | RXD  | +        | Receive Data        |
| 3   | TXD  | <b>→</b> | Transmit Data       |
| 4   | DTR  | <b>→</b> | Data Terminal Ready |
| 5   | GND  |          | System Ground       |
| 6   | DSR  | +        | Data Set Ready      |
| 7   | RTS  | <b>→</b> | Request to Send     |
| 8   | CTS  | +        | Clear to Send       |
| 9   | RI   | +        | Ring Indicator      |

#### Pinos do conector DB9



#### Pinos do conector DB9



Received by DTE Device

Transmitted from DTE Device

#### Conexão RS-232 entre uC e o PC



## RS-232 driver/receiver (MAX232)

- □CI para:
  - □ Ajuste dos níveis lógicos;
  - Inversão para a lógica correta;



### RS-232 driver/receiver (MAX232)



## Comparação RS232, RS422 e RS485

| Especificação                 | RS-232                  | RS-422           | RS-485           |
|-------------------------------|-------------------------|------------------|------------------|
| Modo de operação              | Ponto-a-ponto           | Master/Slave     | Master/Slave     |
| Tipo de transmissão           | Linha não<br>balanceada | Linha balanceada | Linha balanceada |
| Controle tristate da<br>linha | não                     | opcional         | sim              |
| Comprimento máximo de cabo    | 15 m                    | 1.200 m          | 1.200 m          |
| Taxa de transmissão<br>máxima | 20 kbps                 | 10 Mbps          | 10 Mbps          |
| Driver/Receiver numa<br>linha | 1/1                     | 1/10             | 1/32 (1/256)     |

### USB (Universal Serial Bus)

- USB (Universal Serial Bus): taxas de transmissão da ordem de 12 Mbits/s;
- Padrão de Barramento Serial para Interfaces com Dispositivos de E/S
- Conectores:







| Pino | Função             |
|------|--------------------|
| 1    | VBUS $(4,75-5,25)$ |
| 2    | D+                 |
| 3    | D-                 |
| 4    | GND                |

#### Serial Síncrona: SPI e I2C

#### SPI

 Desenvolvido pela *Motorola*, é útil em comunicação full-duplex e adequado em aplicações nas quais se deseja transferir fluxos de dados, tais como na interface com chips periféricos, memórias e até mesmo cartões de memória;

#### I2C

 Desenvolvido na década de 80 pela Philips, tornou-se um padrão conhecido e amplamente utilizado em projetos de circuitos eletrônicos. Sua principal finalidade é permitir a comunicação entre dispositivos onboard;

## Comunicação serial no PIC18F4520

Parâmetros mínimos e máximos da UART

|                   | PIC18F4520          | Porta COM do PC              |
|-------------------|---------------------|------------------------------|
| Baud Rate         | 110 a 1.250.000 bps | 110 a 921.600 bps            |
| No de Bits        | 8 a 9               | 4 a 8                        |
| Bit de paridade   | Não suporta         | Par, impar, marca ou espaço  |
| Stop bit          | 1                   | 1, 1.5 ou 2                  |
| Controle de Fluxo | Não suporta         | Hardware, XON/XOFF ou nenhum |

# Passos para implementação de uma recepção Serial Assíncrona

- 1. Inicializar o registrador SPBRG para o baud rate desejado;
- Configurar os bits RC7:RC6 como entrada;
- 3. Habilitar a porta, SYNC = 0 e SPEN = 1;
- 4. Habilitar a interrupção se for desejado;
- RX9 = 1 se a recepção for de 9 bits;
- Habilitar a recepção, CREN = 1;
- 7. Se ocorrer uma interrupção, o flag de sinalização de interrupção, RCIF = 1;
- 8. Ler o registrador RCSTA para obter o nono bit (RX9D) ou para verificar se houve erro durante a recepção;
- 9. Ler os 8 bits de dados que se encontram em RCREG;
- 10. Se ocorreu algum erro, apagar e setar o bit CREN para que novos dados possam ser recebidos;

# Passos para implementação de uma transmissão Serial Assíncrona

- 1. Inicializar o registrador SPBRG para o baud rate desejado;
- Configurar os bits RC7:RC6 como entrada;
- 3. Habilitar a porta, SYNC = 0 e SPEN = 1;
- 4. Habilitar a interrupção se for desejado;
- 5. RX9 = 1 se a recepção for de 9 bits;
- Habilitar o transmissor, TXEN = 1;
- 7. Se a transmissão for de 9 bits, escrever o nono em TXD9;
- Carregar o dado a ser transmitido em TXREG (a transmissão terá início);
- A transmissão estará finalizada quando o bit TRMT for setado pelo hardware ;ww

#### Registradores FSR da EUART

- Existem três registradores no PIC18F4520 envolvidos com o recurso de serial UART:
  - TXSTA
    - ☐ É um registrador de controle do módulo transmissor da EUSART;
  - RCSTA
    - É um registrador de controle do módulo receptor da EUSART;
  - BAUDCON
    - É um registrador de controle de operação;

## Registradores SFR da EUART

| FFEh         TOSH           FFDh         TOSL           FFCh         STKPTR           FFBh         PCLATU           FFAh         PCLATH           FF9h         PCL           FF8h         TBLPTRU           FF7h         TBLPTRH           FF6h         TBLPTRL           FF5h         TABLAT           FF4h         PRODH           FF3h         PRODL           FF1h         INTCON2           FF0h         INTCON3           FEFh         INDF0(1)           FECH         POSTINCO(1)           FECH         PREINCO(1)           FEBH         PLUSW0(1)           FEBH         FSR0L           FE8h         WREG           FE7h         INDF1(1)           FE6h         POSTINC1(1)           FE6h         POSTINC1(1)           FE5h         POSTDEC1(1)           FE4h         PREINC1(1)           FE3h         PLUSW1(1)           FE3h         PLUSW1(1)           FE3h         PLUSW1(1)           FE3h         FSR1H           FE1h         FSR1L | FFFh | TOSU                  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------|--|
| FFCh STKPTR FFBh PCLATU FFAh PCLATH FF9h PCL FF8h TBLPTRU FF7h TBLPTRH FF6h TBLPTRL FF5h TABLAT FF4h PRODH FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh POSTINCO(1) FECH POSTDECO(1) FECH PREINCO(1) FECH PREINCO(1) FESH WREG FF7h INDF1(1) FESH PSTURCO(1) FESH PSTURCO(1) FESH PSTURCO(1) FESH PLUSWO(1) FESH PREINCO(1) FESH PSTURCO(1) FESH PSTURCO(1) FESH PSTURCO(1) FESH POSTDECO(1) FESH PREINCO(1) FESH FSR1H                                                                                                                                                             | FFEh | TOSH                  |  |
| FFBh         PCLATU           FFAh         PCLATH           FF9h         PCL           FF8h         TBLPTRU           FF7h         TBLPTRH           FF6h         TBLPTRL           FF5h         TABLAT           FF4h         PRODH           FF3h         PRODL           FF2h         INTCON2           FF0h         INTCON3           FEFh         INDF0(1)           FECH         POSTINCO(1)           FECH         PREINCO(1)           FECH         PREINCO(1)           FEAH         FSR0H           FE9h         FSR0L           FE8h         WREG           FE7h         INDF1(1)           FE6h         POSTDEC1(1)           FE5h         POSTDEC1(1)           FE4h         PREINC1(1)           FE3h         PLUSW1(1)           FE3h         PLUSW1(1)           FE3h         PLUSW1(1)           FE3h         PLUSW1(1)           FE3h         PLUSW1(1)                                                                                    | FFDh | TOSL                  |  |
| FFAh PCLATH FF9h PCL FF8h TBLPTRU FF7h TBLPTRH FF6h TBLPTRL FF5h TABLAT FF4h PRODH FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh INDF0(1) FEEh POSTINC0(1) FECH PREINC0(1) FEBH PLUSW0(1) FEBH FSROL FE9h FSROL FE8h WREG FE7h INDF1(1) FE6h POSTINC1(1) FE6h FSROL FE8h WREG FF7h INDF1(1) FE6h POSTINC1(1) FE6h POSTINC1(1) FE5h POSTDEC1(1) FE4h PREINC1(1) FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                      | FFCh | STKPTR                |  |
| FF9h PCL FF8h TBLPTRU FF7h TBLPTRH FF6h TBLPTRL FF5h TABLAT FF4h PRODH FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh INDF0(1) FEEh POSTINCO(1) FECh PREINCO(1) FECH PREINCO(1) FEBH FSROL FE8h WREG FE7h INDF1(1) FE6h POSTINC1(1) FE6h POSTINC1(1) FE8h PREINC1(1) FE8h FSROL FE8h WREG FF7h INDF1(1) FE6h POSTINC1(1) FE6h POSTINC1(1) FE6h POSTINC1(1) FE5h POSTDEC1(1) FE5h FSROL FE8h FSROL FE8H WREG FF7H INDF1(1) FE6H POSTINC1(1) FE5H FSROL FE8H FSROL                                                                                                                                                                                                                                               | FFBh | PCLATU                |  |
| FF8h TBLPTRU FF7h TBLPTRH FF6h TBLPTRL FF5h TABLAT FF4h PRODH FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh INDF0(1) FEEH POSTINCO(1) FEDH POSTDECO(1) FECH PREINCO(1) FEBH PLUSWO(1) FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1(1) FE6H POSTINC1(1) FE6H POSTINC1(1) FE6H POSTINC1(1) FE6H FSROL FE8H WREG FE7H INDF1(1) FE6H POSTDEC1(1) FE6H POSTDEC1(1) FE6H PREINC1(1) FE5H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FFAh | PCLATH                |  |
| FF7h TBLPTRH FF6h TBLPTRL FF5h TABLAT FF4h PRODH FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh POSTINCO(1) FECH POSTDECO(1) FECH PREINCO(1) FECH PREINCO(1) FEBH PLUSWO(1) FESH WREG FE7h INDF1(1) FE6h POSTINC1(1) FE6h POSTINC1(1) FE8h WREG FE7h INDF1(1) FE6h POSTDEC1(1) FE6h POSTDEC1(1) FE6h POSTDEC1(1) FE5h POSTDEC1(1) FE5h POSTDEC1(1) FE5h PREINC1(1)                                                                                                                                                                                                                                                                                                                                                                    | FF9h | PCL                   |  |
| FF6h TBLPTRL  FF5h TABLAT  FF4h PRODH  FF3h PRODL  FF2h INTCON  FF1h INTCON3  FE6h INDF0(1)  FECH POSTINCO(1)  FECH PREINCO(1)  FECH POSTINCO(1)  FECH POSTINCO(1)  FECH PREINCO(1)  FECH PREINCO(1)  FECH PREINCO(1)  FECH PREINCO(1)  FECH FSR1H  FECH FSR1H                                                                                                                                                                                                                                                                                                                                                                                                                                                 | FF8h | TBLPTRU               |  |
| FF5h TABLAT FF4h PRODH FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh INDF0(1) FEEh POSTINCO(1) FECH PREINCO(1) FEBH PLUSWO(1) FEAH FSROL FE8H WREG FE7H INDF1(1) FE6H POSTINC1(1) FE6H PREINC1(1) FE7H PREINC1(1) FE7H PREINC1(1) FE7H PREINC1(1) FE7H PREINC1(1) FE7H FSR1H FE7H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | FF7h | TBLPTRH               |  |
| FF4h PRODH FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh INDF0 <sup>(1)</sup> FEEh POSTINCO <sup>(1)</sup> FECH PREINCO <sup>(1)</sup> FEBH PLUSWO <sup>(1)</sup> FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE6H FSROL FE8H FSROL                                                                                                                                                                                                                                                                                                                                                | FF6h | TBLPTRL               |  |
| FF3h PRODL FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh INDF0 <sup>(1)</sup> FEEH POSTINCO <sup>(1)</sup> FEDH POSTDECO <sup>(1)</sup> FECH PREINCO <sup>(1)</sup> FEBH PLUSWO <sup>(1)</sup> FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE5H POSTDEC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | FF5h | TABLAT                |  |
| FF2h INTCON FF1h INTCON2 FF0h INTCON3 FEFh INDF0 <sup>(1)</sup> FEEh POSTINCO <sup>(1)</sup> FECH PREINCO <sup>(1)</sup> FECH PREINCO <sup>(1)</sup> FEBH PLUSWO <sup>(1)</sup> FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE3H PREINC1 <sup>(1)</sup> FE3H PREINC1 <sup>(1)</sup> FE3H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | FF4h | PRODH                 |  |
| FF1h INTCON2 FF0h INTCON3 FEFh INDF0 <sup>(1)</sup> FEEh POSTINCO <sup>(1)</sup> FECh PREINCO <sup>(1)</sup> FECH PREINCO <sup>(1)</sup> FEBH PLUSWO <sup>(1)</sup> FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE4H PREINC1 <sup>(1)</sup> FE3H PLUSW1 <sup>(1)</sup> FE2H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FF3h | PRODL                 |  |
| FF0h INTCON3 FEFh INDF0(1) FEEh POSTINCO(1) FEDH POSTDECO(1) FECH PREINCO(1) FEBH PLUSWO(1) FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1(1) FE6H POSTINC1(1) FE5H POSTDEC1(1) FE4H PREINC1(1) FE4H PREINC1(1) FE3H PLUSW1(1) FE3H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | FF2h | INTCON                |  |
| FEFH INDF0 <sup>(1)</sup> FEEH POSTINCO <sup>(1)</sup> FEDH POSTDECO <sup>(1)</sup> FECH PREINCO <sup>(1)</sup> FESH PLUSWO <sup>(1)</sup> FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE5H PREINC1 <sup>(1)</sup> FE4H PREINC1 <sup>(1)</sup> FE3H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | FF1h | INTCON2               |  |
| FEEH POSTINCO(1) FEDH POSTDECO(1) FECH PREINCO(1) FEBH PLUSWO(1) FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1(1) FE6H POSTINC1(1) FE5H POSTDEC1(1) FE4H PREINC1(1) FE3H PLUSW1(1) FE2H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | FF0h |                       |  |
| FEDh POSTDECO <sup>(1)</sup> FECh PREINCO <sup>(1)</sup> FEBh PLUSWO <sup>(1)</sup> FEAh FSR0H FE9h FSR0L FE8h WREG FE7h INDF1 <sup>(1)</sup> FE6h POSTINC1 <sup>(1)</sup> FE5h POSTDEC1 <sup>(1)</sup> FE4h PREINC1 <sup>(1)</sup> FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FEFh |                       |  |
| FECH PREINCO <sup>(1)</sup> FEBH PLUSWO <sup>(1)</sup> FEAH FSROH FE9H FSROL FE8H WREG FE7H INDF1 <sup>(1)</sup> FE6H POSTINC1 <sup>(1)</sup> FE5H POSTDEC1 <sup>(1)</sup> FE4H PREINC1 <sup>(1)</sup> FE3H PLUSW1 <sup>(1)</sup> FE2H FSR1H FE1H FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FEEh |                       |  |
| FEBh PLUSWO <sup>(1)</sup> FEAh FSR0H FE9h FSR0L FE8h WREG FE7h INDF1 <sup>(1)</sup> FE6h POSTINC1 <sup>(1)</sup> FE5h POSTDEC1 <sup>(1)</sup> FE4h PREINC1 <sup>(1)</sup> FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | FEDh |                       |  |
| FEAh FSR0H FE9h FSR0L FE8h WREG FE7h INDF1(1) FE6h POSTINC1(1) FE5h POSTDEC1(1) FE4h PREINC1(1) FE3h PLUSW1(1) FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FECh |                       |  |
| FE9h FSR0L FE8h WREG FE7h INDF1(1) FE6h POSTINC1(1) FE5h POSTDEC1(1) FE4h PREINC1(1) FE3h PLUSW1(1) FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FEBh | PLUSW0 <sup>(1)</sup> |  |
| FE8h WREG FE7h INDF1 <sup>(1)</sup> FE6h POSTINC1 <sup>(1)</sup> FE5h POSTDEC1 <sup>(1)</sup> FE4h PREINC1 <sup>(1)</sup> FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FEAh | FSR0H                 |  |
| FE7h INDF1 <sup>(1)</sup> FE6h POSTINC1 <sup>(1)</sup> FE5h POSTDEC1 <sup>(1)</sup> FE4h PREINC1 <sup>(1)</sup> FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | FE9h | FSR0L                 |  |
| FE6h POSTINC1 <sup>(1)</sup> FE5h POSTDEC1 <sup>(1)</sup> FE4h PREINC1 <sup>(1)</sup> FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | FE8h |                       |  |
| FE5h POSTDEC1 <sup>(1)</sup> FE4h PREINC1 <sup>(1)</sup> FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FE7h |                       |  |
| FE4h PREINC1 <sup>(1)</sup> FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | FE6h |                       |  |
| FE3h PLUSW1 <sup>(1)</sup> FE2h FSR1H FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | FE5h |                       |  |
| FE2h FSR1H<br>FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FE4h |                       |  |
| FE1h FSR1L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FE3h | PLUSW1 <sup>(1)</sup> |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | FE2h | FSR1H                 |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | FSR1L                 |  |
| FE0h BSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FE0h | BSR                   |  |

| FDFh | INDF2 <sup>(1)</sup>    |
|------|-------------------------|
| FDEh | POSTINC2 <sup>(1)</sup> |
| FDDh | POSTDEC2 <sup>(1)</sup> |
| FDCh | PREINC2 <sup>(1)</sup>  |
| FDBh | PLUSW2 <sup>(1)</sup>   |
| FDAh | FSR2H                   |
| FD9h | FSR2L                   |
| FD8h | STATUS                  |
| FD7h | TMR0H                   |
| FD6h | TMR0L                   |
| FD5h | T0CON                   |
| FD4h | (2)                     |
| FD3h | OSCCON                  |
| FD2h | HLVDCON                 |
| FD1h | WDTCON                  |
| FD0h | RCON                    |
| FCFh | TMR1H                   |
| FCEh | TMR1L                   |
| FCDh | T1CON                   |
| FCCh | TMR2                    |
| FCBh | PR2                     |
| FCAh | T2CON                   |
| FC9h | SSPBUF                  |
| FC8h | SSPADD                  |
| FC7h | SSPSTAT                 |
| FC6h | SSPCON1                 |
| FC5h | SSPCON2                 |
| FC4h | ADRESH                  |
| FC3h | ADRESL                  |
| FC2h | ADCON0                  |
| FC1h | ADCON1                  |
| FC0h | ADCON2                  |

| FBFh         CCPR1H           FBEh         CCPR1L           FBDh         CCPR2H           FBCh         CCPR2H           FBBh         CCPR2L           FBAh         CCP2CON           FB9h         —(2)           FB8h         BAUDCON           FB7h         PWM1CON(3)           FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FADh         TXRFG           FACh         TXSTA           FABh         RCSTA           FA3h         EEDATA           FA6h         EECON1           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         —(2)           FA2h         —(2)           FA2h         —(2)           FA3h         —(2)           FA2h         —(2)           FA3h         — |      |                        |   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------|---|
| FBDh         CCP1CON           FBCh         CCPR2H           FBBh         CCPR2L           FBAh         CCP2CON           FB9h         —(2)           FB8h         BAUDCON           FB7h         PWM1CON(3)           FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FAOH         TXSTA           FABh         RCSTA           FABh         EEADR           FA8h         EEDATA           FA7h         EECON2(1)           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         —(2)           FA2h         —(2)           FA2h         —(2)           FA2h         —(2)           FA3h         —(2)           FA2h         —(2)           FA3h         —(2)           FA2h         — | FBFh | CCPR1H                 |   |
| FBCh         CCPR2H           FBBh         CCPR2L           FBAh         CCP2CON           FB9h         —(2)           FB8h         BAUDCON           FB7h         PWM1CON(3)           FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FAOh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         —(2)                                                                                          | FBEh | CCPR1L                 |   |
| FBBh         CCPR2L           FBAh         CCP2CON           FB9h         —(2)           FB8h         BAUDCON           FB7h         PWM1CON(3)           FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FAOh         TXSTA           FABh         RCSTA           FA3h         —(2)           FA3h         EEDATA           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA3h         —(2)           FA2h         IPR2           FA1h         PIR2                                                                                                                                                                                                                                         | FBDh | CCP1CON                |   |
| FBAh         CCP2CON           FB9h         —(2)           FB8h         BAUDCON           FB7h         PWM1CON(3)           FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FADh         TXREG           FACh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON2(1)           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         —(2)                                                                                        | FBCh | CCPR2H                 |   |
| FB9h         —(2)           FB8h         BAUDCON           FB7h         PWM1CON(3)           FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FAOh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         —(2)                                                                                                 | FBBh | CCPR2L                 |   |
| FB8h         BAUDCON           FB7h         PWM1CON <sup>(3)</sup> FB6h         ECCP1AS <sup>(3)</sup> FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FAOh         TXRFG           FACh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON2 <sup>(1)</sup> FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         —(2)                                                                                                                                             | FBAh | CCP2CON                |   |
| FB7h         PWM1CON(3)           FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FADh         TXRFG           FACh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON1(1)           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         IPR2           FA1h         PIR2                                                                                                                                                                                                                                                                                                                              | FB9h | (2)                    |   |
| FB6h         ECCP1AS(3)           FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FAOh         TXRFG           FACh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON2(1)           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         —(2)           FA2h         —(2)           FA2h         —(2)           FA2h         —(2)           FA2h         —(2)                                                                                                                                                                                                                                                                            | FB8h | BAUDCON                |   |
| FB5h         CVRCON           FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FAOh         TXRFG           FACh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON2(1)           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         IPR2           FA1h         PIR2                                                                                                                                                                                                                                                                                                                                                                                                  | FB7h | PWM1CON <sup>(3)</sup> |   |
| FB4h         CMCON           FB3h         TMR3H           FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FADh         TXREG           FACh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON2(1)           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         IPR2           FA1h         PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                | FB6h | ECCP1AS <sup>(3)</sup> |   |
| FB3h TMR3H FB2h TMR3L FB2h TMR3L FB1h T3CON FB0h SPBRGH FAFh SPBRG FAEh RCREG FACh TXRFG FACh TXSTA FABh RCSTA FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2(1) FA6h EECON1 FA5h —(2) FA4h —(2) FA4h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FB5h | CVRCON                 |   |
| FB2h         TMR3L           FB1h         T3CON           FB0h         SPBRGH           FAFh         SPBRG           FAEh         RCREG           FADh         TXREG           FACh         TXSTA           FABh         RCSTA           FA9h         EEADR           FA8h         EEDATA           FA7h         EECON2(1)           FA6h         EECON1           FA5h         —(2)           FA4h         —(2)           FA2h         IPR2           FA1h         PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | FB4h | CMCON                  |   |
| FB1h T3CON FB0h SPBRGH FAFh SPBRG FAEh RCREG FACh TXRFG FACh TXSTA FABh RCSTA FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | FB3h | TMR3H                  |   |
| FB0h SPBRGH FAFh SPBRG FAEh RCREG FADh TXRFG FACh TXSTA FABh RCSTA FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA4h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FB2h | TMR3L                  |   |
| FAFh SPBRG FAEh RCREG FADh TXREG FACh TXSTA FABh RCSTA FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2(1) FA6h EECON1 FA5h —(2) FA4h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FB1h | T3CON                  |   |
| FAEh RCREG FADh TXRFG FACh TXSTA FABh RCSTA FASh EEADR FA8h EEDATA FA7h EECON2(1) FA6h EECON1 FA5h —(2) FA4h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FB0h | SPBRGH                 |   |
| FADh TXREG FACh TXSTA FABh RCSTA FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | FAFh | SPBRG                  |   |
| FACh TXSTA FABh RCSTA FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FAEh | RCREG                  |   |
| FABh RCSTA FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2(1) FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | FADh | TXRFG                  | _ |
| FAAh —(2) FA9h EEADR FA8h EEDATA FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FACh | TXSTA                  |   |
| FA9h EEADR FA8h EEDATA FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FABh |                        |   |
| FA8h EEDATA FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | FAAh | (2)                    | Г |
| FA7h EECON2 <sup>(1)</sup> FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | FA9h | EEADR                  |   |
| FA6h EECON1 FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FA8h |                        |   |
| FA5h —(2) FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | FA7h | EECON2 <sup>(1)</sup>  |   |
| FA4h —(2) FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | FA6h |                        |   |
| FA3h —(2) FA2h IPR2 FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FA5h |                        |   |
| FA3h IPR2<br>FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | FA4h |                        |   |
| FA1h PIR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FA3h |                        |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FA2h | IPR2                   |   |
| FA0h PIE2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FA1h | PIR2                   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FA0h | PIE2                   |   |

| F9Fh | IPR1                 |
|------|----------------------|
| F9Eh | PIR1                 |
| F9Dh | PIE1                 |
| F9Ch | (2)                  |
| F9Bh | OSCTUNE              |
| F9Ah | (2)                  |
| F99h | (2)                  |
| F98h | (2)                  |
| F97h | (2)                  |
| F96h | TRISE <sup>(3)</sup> |
| F95h | TRISD <sup>(3)</sup> |
| F94h | TRISC                |
| F93h | TRISB                |
| F92h | TRISA                |
| F91h | (2)                  |
| F90h | (2)                  |
| F8Fh | (2)                  |
| F8Eh | (2)                  |
| F8Dh | LATE <sup>(3)</sup>  |
| F8Ch | LATD <sup>(3)</sup>  |
| F8Bh | LATC                 |
| F8Ah | LATB                 |
| F89h | LATA                 |
| F88h | (2)                  |
| F87h | (2)                  |
| F86h | (2)                  |
| F85h | (2)                  |
| F84h | PORTE <sup>(3)</sup> |
| F83h | PORTD <sup>(3)</sup> |
| F82h | PORTC                |
| F81h | PORTB                |
| F80h | PORTA                |

## Registradores – TXSTA

| R/W-0 | R/W-0 | R/W-0               | R/W-0 | R/W-0 | R/W-0 | R-1  | R/W-0 |
|-------|-------|---------------------|-------|-------|-------|------|-------|
| CSRC  | TX9   | TXEN <sup>(1)</sup> | SYNC  | SENDB | BRGH  | TRMT | TX9D  |
| bit 7 |       |                     |       |       |       |      | bit 0 |

| bit 3 | SENDB: Send Break Character bit  Asynchronous mode:  1 = Send Sync Break on next transmission  0 = Sync Break transmission completed  Synchronous mode:  Don't care. | bit 7          | CSRC: Clock Source Select bit  Asynchronous mode: Don't care.  Synchronous mode:  1 = Master mode (clock generated internally 0 = Slave mode (clock from external source)            |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 2 | BRGH: High Baud Rate Select bit  Asynchronous mode:  1 = High speed 0 = Low speed  Synchronous mode: Unused in this mode.                                            | bit 6<br>bit 5 | TX9: 9-Bit Transmit Enable bit  1 = Selects 9-bit transmission  0 = Selects 8-bit transmission  TXEN: Transmit Enable bit <sup>(1)</sup> 1 = Transmit enabled  0 = Transmit disabled |
| bit 1 | TRMT: Transmit Shift Register Status bit  1 = TSR empty 0 = TSR full  TX9D: 9th Bit of Transmit Data                                                                 | bit 4          | SYNC: EUSART Mode Select bit  1 = Synchronous mode  0 = Asynchronous mode                                                                                                            |
| bit 0 | 0 = TSR full                                                                                                                                                         | -              | 1 = Synchronous                                                                                                                                                                      |

#### Registradores – RCSTA

| R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0  | R-0  | R-x  |  |
|-------|-------|-------|-------|-------|------|------|------|--|
| SPEN  | RX9   | SREN  | CREN  | ADDEN | FERR | OERR | RX9D |  |
| bit 7 |       |       |       |       |      |      |      |  |

bit 3 ADDEN: Address Detect Enable bit

Asynchronous mode 9-Bit (RX9 = 1):

1 = Enables address detection, enables interrupt and loads the receive buffer when RSR<8> is set

0 = Disables address detection, all bytes are received and ninth bit can be used as parity bit

Asynchronous mode 9-Bit (RX9 = 0):

Don't care.

bit 2 FERR: Framing Error bit

1 = Framing error (can be cleared by reading RCREG register and receiving next valid byte)

0 = No framing error

bit 1 OERR: Overrun Error bit

1 = Overrun error (can be cleared by clearing bit, CREN)

0 = No overrun error

bit 0 RX9D: 9th Bit of Received Data

This can be address/data bit or a parity bit and must be calculated by user firmware.

#### Registradores – RCSTA

| R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R-0  | R-0  | R-x   |
|-------|-------|-------|-------|-------|------|------|-------|
| SPEN  | RX9   | SREN  | CREN  | ADDEN | FERR | OERR | RX9D  |
| bit 7 |       |       |       |       |      |      | bit 0 |

bit 7 SPEN: Serial Port Enable bit

1 = Serial port enabled (configures RX/DT and TX/CK pins

0 = Serial port disabled (held in Reset)

bit 6 RX9: 9-Bit Receive Enable bit

1 = Selects 9-bit reception0 = Selects 8-bit reception

bit 5 SREN: Single Receive Enable bit

Asynchronous mode:

Don't care.

Synchronous mode - Master:

1 = Enables single receive0 = Disables single receive

This bit is cleared after reception is complete.

Synchronous mode - Slave:

Don't care.

bit 4 CREN: Continuous Receive Enable bit

Asynchronous mode:

1 = Enables receiver 0 = Disables receiver

Synchronous mode:

1 = Enables continuous receive until enable bit, CREN, is

0 = Disables continuous receive

#### Registradores - BAUDCON

| R/W-0  | R-1   | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 |
|--------|-------|-------|-------|-------|-----|-------|-------|
| ABDOVF | RCIDL | RXDTP | TXCKP | BRG16 | _   | WUE   | ABDEN |
| bit 7  |       |       |       |       |     |       |       |

bit 3 BRG16: 16-Bit Baud Rate Register Enable bit

1 = 16-bit Baud Rate Generator - SPBRGH and SPBRG

0 = 8-bit Baud Rate Generator - SPBRG only (Compatible mode), SPBRGH value ignored

bit 2 Unimplemented: Read as '0'

bit 1 WUE: Wake-up Enable bit

#### Asynchronous mode:

1 = EUSART will continue to sample the RX pin – interrupt generated on falling edge; bit cleared in hardware on following rising edge

0 = RX pin not monitored or rising edge detected

#### Synchronous mode:

Unused in this mode.

bit 0 ABDEN: Auto-Baud Detect Enable bit

#### Asynchronous mode:

- 1 = Enable baud rate measurement on the next character. Requires reception of a Sync field (55h); cleared in hardware upon completion.
- 0 = Baud rate measurement disabled or completed

#### Synchronous mode:

Unused in this mode.

#### Registradores - BAUDCON

| R/W-0       | R-1   | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 |
|-------------|-------|-------|-------|-------|-----|-------|-------|
| ABDOVF      | RCIDL | RXDTP | TXCKP | BRG16 | _   | WUE   | ABDEN |
| bit 7 bit 0 |       |       |       |       |     |       |       |

bit 7 ABDOVF: Auto-Baud Acquisition Rollover Status bit

1 = A BRG rollover has occurred during Auto-Baud Rate Detect mode (must be cleared in software)

0 = No BRG rollover has occurred

bit 6 RCIDL: Receive Operation Idle Status bit

1 = Receive operation is Idle0 = Receive operation is active

RXDTP: Data/Receive Polarity Select bit

Asynchronous mode:

1 = Receive data (RX) is inverted (active-low)

0 = Receive data (RX) is not inverted (active-high)

Synchronous mode:

1 = Data (DT) is inverted (active-low)

0 = Data (DT) is not inverted (active-high)

bit 4 TXCKP: Clock and Data Polarity Select bit

Asynchronous mode:

1 = Idle state for transmit (TX) is a low level

0 = Idle state for transmit (TX) is a high level

Synchronous mode:

1 = Idle state for clock (CK) is a high level

0 = Idle state for clock (CK) is a low level

bit 5

### Esquema Elétrico



### Serial UART (Código-fonte)

LCD\_8bits.h

Arquivo cabeçalho com as definições dos pinos utilizados como via de dados, vias de controle e os protótipos das funções;

• LCD\_8bits.c

Arquivo que contém as funções de acesso ao LCD;

Main\_39.c

Arquivo principal responsável por receber uma um dado pela UART, retransmitir e, na seqüência, enviar para o LCD;

## Display LCD / Funções

| Função           | Descrição                                                                               |
|------------------|-----------------------------------------------------------------------------------------|
| IniciaLCD        | Inicializa LCD controller                                                               |
| TestPixelsLCD    | Acende todos os pixels do LCD                                                           |
| EscInstLCD       | Envia instrução para o LCD                                                              |
| EscDataLCD       | Escreve um caractere na posição apontada pelo cursor                                    |
| EscStringLCD     | Escreve uma string lida na memória de dados a partir da posição apontada pelo cursor    |
| EscStringLCD_ROM | Escreve uma string lida na memória de programa a partir da posição apontada pelo cursor |
| TesteBusyFlag    | Verifica se o LCD <i>controller</i> está ocupado executando alguma instrução            |
| Pulse            | Aplica pulso de para leitura ou escrita no LCD                                          |
| _Delay100us      | Delay de 100us                                                                          |
| _Delay5ms        | Delay de 5ms                                                                            |
| DelayFor20TCY    | Delay de 20 ciclos de instrução do oscilador                                            |

#### LCD\_8bits.h

```
#ifndef LCD 8BITS H Identificador que impede a definição a seguir seja duplicada se o arquivo
     #define LCD_8BITS_H
                            cabeçalho foi incluído em outro arquivo-fonte associado ao projeto.
10
11
     //definições do port ligado no LCD
12
     13
     #define PORT_CONT_LCD PORTE
14
     #define TRIS_PORT_LCD TRISD //direção dos pinos
#define TRIS_CONT_LCD TRISE //direção dos pinos
15
16
17
18
     //definições dos pinos de controle
     19
20
21
22
23
     //protótipos de funções
24
     void IniciaLCD (unsigned char NL);
25
     void Pulse(void);
26
     void Delay100us(void);
27
     void Delay5ms(void);
28
     void TestPixelsLCD(void);
29
     void DelayFor20TCY( void);
30
     void DelayFor18TCY( void);
31
     unsigned char TesteBusyFlag(void);
32
     void EscDataLCD(char data);
33
     void EscInstLCD(unsigned char inst);
34
     void EscStringLCD(char *buffer);
35
     void EscStringLCD ROM(const rom char *buffer);
36
37
     #endif
38
```

```
/*****************
10
   Esta biblioteca contém um conjunto de funções que permitem ao microcontrolador
11
   se comunicar com o LCD controller HD44780.
   12
   13
14
15
16
17
   A função IniciaLCD() recebe como argumento um valor que irá inializar o LCD com:
18
19
   valor = 1 -> inicializa o LCD com uma linha
20
   valor != 1 -> inicializa o LCD com linha dupla
21
22
   Quando o programa retorna ao ponto de chamada, o LCD mostra o cursor piscando
23
   na primeira posição da primeira linha.
   24
```

```
25
                           void IniciaLCD (unsigned char NL)
                    26
                              const unsigned char Seq Inic[3] = {0x0F, 0x06, 0x01};
                    27
                                                                                        //declaração de vetor
                    28
                                                                              //declaração de variável local
                              unsigned char i;
                    29
                                                                              //declaração de variável local
                              char x:
                     30
                              EN = 0:
                                                            //envia intrução
                     31
                              RS = 0;
                                                            //limpa pino enable
                     32
                               RW = 0;
                                                            //ativa ciclo de escrita
NL: Define o número
                     33
                              ADCON1 = 0x0F;
                                                               //configura PORT de controle com digital
de linhas que estarão
                     34
                              TRIS CONT LCD = 0;
                                                                //configura PORT de controle como saída
ativas;
                     35
                                                                //configura PORT de dados como saída
                              TRIS PORT LCD = 0;
                     36
                               ******* envia para o LCD o comando 0x30 três vezes
                     37
                              for(i=0;i<3;i++)
                     38
                     39
                                 PORT LCD = 0x30;
                                                                comando 0x30
                    40
                                 Pulse();
                                                              aplica pulso enable no LCD
                     41
                                  Delay5ms();
                                                              /delay 5ms
                     42
                     43
                               ******** configura
                                                           simples ou linha dupla
                     44
                                                      0x30
                              if (NL == 1) PORT LCD =
                                                                 //se NL=1, ativa uma linha
                     45
                              else PORT LCD =
                                                                 //se NL!=1, ativa duas linhas
                     46
                              Pulse();
                                                            //aplica pulso enable no LCD
                     47
                               Delay5ms();
                                                             //delay 5ms
                     48
                     49
                              for(i=0;i<3;i++)
                     50
                     51
                                 PORT LCD = Seq Inic[i];
                                                                  //LCD recebe comando
                     52
                                 Pulse();
                                                            //aplica pulso enable no LCD
                     53
                                 Delay5ms();
                                                             //delay 5ms
                    54
                    55
                              TRIS PORT LCD = 0xFF;
                                                                //configura PORT de dados como entrada
                     56
                                                           //final da função IniciaLCD
```

### Serial EUART (Código-fonte) - 3

São utilizadas para gerar a base de tempo exigida pelo LCD 58

59

60

61

62

63

64

65

66

67

68 69

70

71 72

73

75

76

78

80

82

83

85

86

Precisam que o arquivo cabeçalho delay.h seja incluído no projeto.

Desenvolvida para freqüência de clock de 8Mhz.

```
//esta função escreve comando/dado no LCD
void Pulse (void)
  DelayFor20TCY(); //delay de 20 ciclos de clock
                          //seta pino enable
   EN = 1;
  DelayFor20TCY();
                              //delay de 20 ciclos de clock
   EN = 0;
                              //limpa pino enable
                     funções de delay
//delay de 100us
void Delay100us(void)
  Delav100TCYx(2);
                              //delav 100us
//delay de 5ms
void Delay5ms(void)
  Delay10KTCYx(1);
                               //delav 5ms
//delay 20 ciclos do oscilador principal
void DelayFor20TCY( void
   Nop(); Nop(); Nop(); Nop(); Nop();
  Nop(); Nop(); Nop(); Nop();
  Nop(); Nop(); Nop(); Nop();
```

### Serial EUART (Código-fonte) - 4

Verifica se o LCD está ocupado executando alguma instrução ou se ele está livre;

```
void DelayFor18TCY( void )
 96
 97
 98
           Nop(); Nop(); Nop(); Nop(); Nop(); Nop();
 99
           Nop(); Nop(); Nop(); Nop(); Nop(); Nop();
100
101
102
                     funções de acesso ao LCD
103
       /*esta função fica aguardando o LCD controller terminar de executar
104
105
       a instrução atual. ela retorna o valor 0 quando a instrução terminar.*/
       unsigned char TesteBusyFlag(void)
106
107
108
            TRIS PORT LCD = 0xFF; //configura PORT de dados como entrada
109
110
            RW = 1:
                                            //ativa ciclo de leitura
111
           RS = 0:
                                       //ciclo de intrução
112
           DelayFor20TCY();
                                          //delay de 20 cliclos de clock
113
            EN = 1;
                                                  //seta pino enable
114
           DelayFor20TCY();
                                          //delay de 20 cliclos de clock
115
          if (PORT LCD&0x80)
                                               //leitura do bit busy flag
116
                                                 //se bit busy == 1, LCD ocupado
              EN = 0;
117
                                             //reseta pino enable
118
                RW = 0:
                                             //reseta linha de escrita
119
                                                //LCD ocupado, retorna 1
               return 1;
120
121
           else
                                               //se busy flag == 0, LCD livre
122
123
                EN = 0;
                                               //reseta pino enable
124
                RW = 0:
                                              //ativa ciclo de escrita
125
               return 0:
                                             //LCD livre, retorna 0
126
```

```
128
                          //esta função escreve um caractere na pocição apontada pelo cursor.
                   129
                        void EscDataLCD(char data)
                   130
                   13½
1/32
                             TRIS PORT LCD = 0:
                                                             //configura PORT de dados como saída
Verifica se o LCD
                             PORT LCD = data;
                                                             //escreve dado
está ocupado
                   133
                             RS = 1;
                                                          //envia dado
executando alguma
                   134
                             RW = 0;
                                                          //ativa ciclo de escrita
instrução ou se ele
                   135
                                                          //aplica pulso enable no LCD
                             Pulse();
está livre;
                   136
                                                         //envia instrução
                             RS = 0:
                              _RS = 0;
DelayFor20TCY();
                   137
                                                          //delay de 20 ciclos de clock
                   138
                             TRIS_PORT_LCD = 0xFF; //configura PORT de dados como entrada
                   139
                                              //final da função EscDataLCD
                   140
                   141
                   142
                          //esta função envia uma instrução para o LCD.
                   143
                        void EscInstLCD(unsigned char inst)
                   144
                   145
                             TRIS PORT LCD = 0:
                                                              //configura PORT de dados como saída
Verifica se o LCD
                   1/46
                             PORT LCD = inst;
                                                             //escreve instrução
está ocupado
                   147
                                                          //envia intrução
                             RS = 0;
executando alguma
                   148
                                                          //ativa ciclo de escrita
                              RW = 0;
instrução ou se ele
                   149
                                                          //aplica pulso enable no LCD
                             Pulse();
está livre;
                   150
                             RS = 0;
                                                         //envia dado
                             DelayFor20TCY();
                   151
                                                          //delay de 20 ciclos de clock
                             TRIS_PORT_LCD = 0xFF; //configura PORT de dados como entrada
                   152
                   153
                   154
                                                        //final da função EscInstLCD
```

### Serial EUART (Código-fonte) - 6

Envia para o LCD a string lida na memória de dados que será exibida no display a partir da posição apontado pelo cursor;

156

157

158

159

160 161

162

163

164

165

166

167 168

169

170

171 172

173

174

175

176 177

178

179

180 181

182 183

Envia para o LCD a *string* lida na memória de programa que será exibida no *display* a partir da posição apontado pelo cursor;

```
da posição aponntada pelo cursor.*/
 #pragma code My codigo = 0x200
□ void EscStringLCD (char *buff)
    while(*buff)
                               //escreve caractere até econtrar null
     EscDataLCD(*buff); //escreve no LCD caractere apontado por bufff
       buff++;
                           // Incrementa buffer
              ***********
                        //final da função EscStringLCD
 #pragma code
 /*esta função escreve no LCD uma string lida da memória de programa
 a partir da posição aponntada pelo cursor.*/
void_EscStringLCD_ROM(const_rom_char_*buff)
    while(*buff)
                               // Write data to LCD up to null
     //escreve no LCD caractere apontado por buf
       EscDataLCD(*buff);
       buff++;
                              // Incrementa buffer
       return:
                        //final da função EscStringLCD ROM
```

/\*esta função escreve no LCD uma string lida da memória RAM a partir

```
//esta função testa o LCD acendendo todos os pixels do display.
                     186

  void TestPixelsLCD(void)

                     187
                      188
                             unsigned char BffCheio[32]
                                                                      //declaração de vetor
                     189
                             unsigned char i;
                                                                 //declaração de variável local
                     190
                                EscInstLCD(0x80);
                                                                 //posiciona cursor na primeira posição da primeira linha
Função que acende
                     191
                                                                     //espera LCD controller terminar de executar instrução
                                while (TesteBusyFlag());
todos os pixels do
                     192
display do LCD;
                     193
                                                                 //laço de iteração
                                for(i=0;i<32;i++)
                      194
                      195
                                   if(i<16)
                                                              //i < 16?
                      196
                                                             //sim, executa bloco de código a seguir
                                                                 //escreve caractere na posição pantada pelo
 Escreve cursor na
                     197
                                      EscDataLCD(0xFF);
                     198
                                      while (TesteBusyFlag());
                                                                     //espera LCD controller terminar de executar instrução
 primeira linha
                     199
                      200
                                                                 //i==16?
                                   else
                                            if(i==16)
                      201
                                                              //sim, executa bloco de código a seguir
                     202
                                      EscInstLCD(0xC0);
                                                                 //posiciona cursor na primeira posição da segunda linha
 Posiciona cursor na
                     203
                                      while (TesteBusyFlag());
                                                                     //espera LCD controller terminar de executar instrução
 segunda linha
                      204
                      205
                                      EscDataLCD(0xFF);
                                                                  //escreve caractere na posição pantada pelo
                     206
207
                                      while (TesteBusyFlag());
                                                                     //espera LCD controller terminar de executar instrução
                     208
                                   else
                                                             //se i !=16 executa bloco de c[odigo a seguir
Caractere com todos
                     409
os pixels acesos
                     210
                                      EscDataLCD(0xFF);
                                                                 //escreve caractere na posição pantada pelo
                      211
                                      while (TesteBusyFlag());
                                                                     //espera LCD controller terminar de executar instrução
                     212
                     213
                     214
                     215
```

```
10
11
   //protótipos de funções
12
   void Inic Regs (void);
13
   void Atual LCD (char dado);
14
   void Configura UART (void);
15
   void Transmite UART (char dado);
16
17
   //variáveis globais
18
    char count=0;
   //***************
19
20
                    //função main

□ void main (void)

21
                  //declaração de variável local inicializada
    float x=0:
                          //declaração de variável local inicializada
23
    int dly=0;
24
                          //declaração de variável local inicializada
    char DADO;
25
    //************
26
      Inic_Regs (); //configurar SFRs
27
    //*************
28
      IniciaLCD (2);
                         //inicializar LCD controller HD44780
     TestPixelsLCD(); //teste no LCD - acende todos os pixels.
29
30
31
     EscInstLCD(0x0C); //desativa cursor
      32
```

```
31
      EscInstLCD(0x0C);
                            //desativa cursor
32
                            //espera LCD controller terminar de executar
      while (TesteBusyFlag());
33
34
    //delay de 3 segundos
35
      for(dly=0;dly<600;dly++) //comando de iteração
36
37
        Delay5ms();
                      //delav de 5ms
38
39
40
      EscInstLCD(0x01);
                    //desativa cursor
    41
42
    43
44
45
    //rotina principal
46
      while (1)
47
48
        while(!PIR1bits.RCIF); //aguarda chegar um novo byte
                             //houve erro de transmissão?
49
        if (RCSTAbits.FERR)
50
          RCSTAbits.CREN = 0;
51
                               //sim, desabilita recepção
52
          RCSTAbits.CREN = 1;
                               //habilita recepção
53
54
        else
                           //não houve erro de transmissão, transmite dado
55
56
          DADO = RCREG; //obtém caractere
57
        58
         Atual LCD(DADO); //atualiza LCD
59
```

```
void Inic Regs (void)
66
67
                                     //PORTA saída
        TRISA = 0x00;
68
        TRISB = 0x00;
                                    //PORTB saída
69
                                    //PORTC saída
        TRISC = 0x00;
70
                                       //PORTD saida
        TRISD = 0x00;
71
                                     //PORTE saída
        TRISE = 0x00;
72
                                      //configura pinos dos PORTA e PORTE
        ADCON1 = 0x0F;
73
                                      //limpa PORTA
        PORTA = 0;
                                      //limpa PORTB
        PORTB = 0;
75
        PORTC = 0;
                                      //limpa PORTC
76
                                      //apaga displays
        PORTD = 0x00;
77
                                      //limpa PORTE
        PORTE = 0;
     }//********
78
79
     //inicializa USART
80
    □ void Configura UART (void)
81
82
        TRISCbits.TRISC7 = 1; //configura pino RX como entrada
83
        TRISCbits.TRISC6 = 1;
                                    //configura pino TX como entrada
84
                                     //transmissão habilitada<5>
        TXSTA = 0b00100100;
85
                                //transmissão assincrona<4>
86
                                //transmissão em alta velocidade<2>
87
        RCSTA = 0b10010000;
                                       //porta serial habilitada<7>
88
                                //recepção contínua habilitada<4>
89
        BAUDCON = 0b00000000;
                                       //TX ocioso em nível alto<4>
90
                                //gerador de baud rate de 8 bits<3>
91
        SPBRG = 207;
                                  //2400bps
92
```

```
//transmite o caractere
    □ void Transmite UART (char dado)
 95
 96
         TXREG = dado:
                         //inicia a transmissão
 97
                                  //aguarda transmissão terminar
         while(TXSTAbits.TRMT);
 98
 99
      //função que atualiza o LCD.
100
     void Atual LCD (char dado)
101
102
         if (count==16)
                                     //se cursor chegou no final da primeira linha
103
104
            EscInstLCD(0xC0); //move cursor para a primeira posição da segunda linha
105
            while (TesteBusyFlag()); //espera LCD controller terminar de executar instrução
106
107
         else if (count==32) //se cursor chegou no final da segunda linha
108
109
            EscInstLCD(0x01); //limpa display e mostra cursor piscando na primeira posição da
110
            while (TesteBusyFlag()); //espera LCD controller terminar de executar instrução
111
112
         EscDataLCD(dado); //escreve caractere no LCD na posição apontada pelo cursor
113
         while (TesteBusyFlag()); //espera LCD controller terminar de executar instrução
114
                                 //incrementa count
         count+=1:
115
116
```

### Serial EUART (Código-fonte) - Ex.10.2

Transmissão de uma string:

```
#include <p18f4520.h>
      #include "pic simb.h"
 3
 4
     #pragma config OSC = XT, WDT = OFF, MCLRE = ON
 5
     *pragma config DEBUG = OFF, LVP = OFF, PWRT = ON, BOREN = OFF
 6
   □ void MCU init(void)
 8
        TRISCbits.TRISC6 = 0; // configura RC6(TX) como saída
10
        TXSTA = bTXEN | bBRGH; // TXSTA = 0x24 -> TXEN=1 e BRGH=1
                                 // RCSTA = 0x80 -> SPEN=1
        RCSTA = bSPEN;
12
         SPBRG = 25; // configura a velocidade da EUSART (9600bps para Fosc = 4MHz)
13
   □ void EUSART envia string(char *string)
16
17
        while (*string)
18
19
           while (!PIR1bits.TXIF); // aguarda espaço no buffer de TX
20
           TXREG = *string; // envia um caractere
                       // avança para o próximo caractere
           string++;
22
23
24
   □ void main(void)
26
27
         char str[11]="Ola Mundo!";
        MCU init();
29
        EUSART envia string(str);
         while (1);
```

### Serial EUART (Código-fonte) - Ex.10.3

Recepção de uma string:

```
#include <p18f4520.h>
      #include "pic simb.h"
     #pragma config OSC = XT, WDT = OFF, MCLRE = ON
     *pragma config DEBUG = ON, LVP = OFF, PWRT = ON, BOREN = OFF
     #define L1
                     LATBbits.LATB0
     #pragma interrupt EUSART RX ISR
    □ void EUSART RX ISR(void)
11
12
        TXREG = RCREG+1; // retransmite o dado recebido (+1)
13
        L1 = !L1; // muda o estado do led L1
14
15
     #pragma code isr baixa = 0x0008

□ void ISR baixa_prioridade(void)

18
        if (PIR1bits.RCIF) asm BRA EUSART RX ISR endasm
19
20
21
     #pragma code
22
23

□ void MCU init (void)

24
25
        TRISCbits.TRISC6 = 0; // pino RC6(TX) como saída
26
        TRISBbits.TRISB0 = 0; // pino RB0 (led) como saída
27
        TXSTA = bTXEN | bBRGH; // TXSTA = 0x24 -> TXEN=1 e BRGH=1
28
        RCSTA = bSPEN | bCREN; // RCSTA = 0x80 -> SPEN=1 e CREN=1
29
                         // configura a velocidade da EUSART (9600 bps)
        SPBRG = 25;
30
        PIE1bits.RCIE = 1; // habilita a interrupção de recepção da EUSART
        INTCON = bGIE | bPEIE; // habilita interrupções
```

### Próxima Aula

# Aula 18 Modulação PWM